home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Aminet 37
/
Aminet 37 (2000)(Schatztruhe)[!][Jun 2000].iso
/
Aminet
/
dev
/
lang
/
sofa.lha
/
sofa
/
smalleiffel
/
lib_se
/
e_inspect.e
< prev
next >
Wrap
Text File
|
2000-03-25
|
9KB
|
307 lines
-- This file is part of SmallEiffel The GNU Eiffel Compiler.
-- Copyright (C) 1994-98 LORIA - UHP - CRIN - INRIA - FRANCE
-- Dominique COLNET and Suzanne COLLIN - colnet@loria.fr
-- http://SmallEiffel.loria.fr
-- SmallEiffel is free software; you can redistribute it and/or modify it
-- under the terms of the GNU General Public License as published by the Free
-- Software Foundation; either version 2, or (at your option) any later
-- version. SmallEiffel is distributed in the hope that it will be useful,but
-- WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
-- or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
-- for more details. You should have received a copy of the GNU General
-- Public License along with SmallEiffel; see the file COPYING. If not,
-- write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
-- Boston, MA 02111-1307, USA.
--
class E_INSPECT
--
-- The Eiffel inspect instruction.
--
inherit INSTRUCTION;
creation make
feature
start_position: POSITION;
-- Of keyword `inspect'.
expression: EXPRESSION;
-- Heading expression after keyword `inspect'.
when_list: WHEN_LIST;
-- List of when clauses.
else_position: POSITION;
-- Of the keyword `else' if any.
else_compound: COMPOUND;
-- Else compound if any.
feature {NONE}
current_type: TYPE;
feature {NONE}
make(sp: like start_position; exp: like expression) is
require
not sp.is_unknown;
exp /= Void;
do
start_position := sp;
expression := exp;
ensure
start_position = sp;
expression = exp;
end;
feature
is_pre_computable: BOOLEAN is false;
end_mark_comment: BOOLEAN is true;
feature
afd_check is
do
expression.afd_check;
if when_list /= Void then
when_list.afd_check;
end;
if else_compound /= Void then
else_compound.afd_check;
end;
end;
includes(v: INTEGER): BOOLEAN is
-- True if a when clause includes `v'.
do
Result := when_list.includes_integer(v);
end;
collect_c_tmp is
do
end;
compile_to_c is
local
no_check: BOOLEAN;
debug_check: BOOLEAN;
do
no_check := run_control.no_check;
debug_check := run_control.debug_check;
cpp.inspect_incr;
cpp.put_string("{int ");
cpp.put_inspect;
cpp.put_character('=');
if debug_check then
cpp.put_character('(');
cpp.se_trace_exp(expression.start_position);
cpp.put_character(',');
end;
expression.compile_to_c;
if debug_check then
cpp.put_character(')');
end;
cpp.put_string(fz_00);
if when_list = Void then
if else_position.is_unknown then
if no_check then
exceptions_handler.incorrect_inspect_value(start_position);
end;
elseif else_compound /= Void then
else_compound.compile_to_c;
end;
else
when_list.compile_to_c(else_position);
if else_position.is_unknown then
if no_check then
cpp.put_character(' ');
cpp.put_string(fz_else);
cpp.put_character('{');
exceptions_handler.incorrect_inspect_value(start_position);
cpp.put_character('}');
end;
elseif else_compound /= Void then
cpp.put_character(' ');
cpp.put_string(fz_else);
cpp.put_character('{');
else_compound.compile_to_c;
cpp.put_character('}');
end;
end;
cpp.put_string(fz_12);
cpp.inspect_decr;
end;
compile_to_jvm is
do
expression.compile_to_jvm;
if when_list /= Void then
when_list.compile_to_jvm(else_position);
end;
if else_compound /= Void then
else_compound.compile_to_jvm;
elseif else_position.is_unknown then
if run_control.no_check then
code_attribute.runtime_error_inspect(expression);
end;
end;
if when_list /= Void then
when_list.compile_to_jvm_resolve_branch;
end;
code_attribute.opcode_pop;
end;
use_current: BOOLEAN is
do
Result := Result or else expression.use_current;
if when_list /= Void then
Result := Result or else when_list.use_current;
end;
if else_compound /= Void then
Result := Result or else else_compound.use_current;
end;
end;
stupid_switch(r: ARRAY[RUN_CLASS]): BOOLEAN is
do
Result := expression.stupid_switch(r) and then
(when_list = Void or else when_list.stupid_switch(r)) and then
(else_compound = Void or else else_compound.stupid_switch(r));
end;
add_when(e_when: E_WHEN) is
require
e_when /= Void
do
if when_list = Void then
!!when_list.make(e_when);
else
when_list.add_last(e_when);
end;
end;
set_else_compound(sp: like else_position; ec: like else_compound) is
do
else_position := sp;
else_compound := ec;
end;
to_runnable(ct: TYPE): like Current is
local
e: like expression;
te: TYPE;
wl: WHEN_LIST;
do
if current_type = Void then
current_type := ct;
e := expression.to_runnable(ct);
if nb_errors = 0 then
expression := e;
te := e.result_type.run_type;
-- ********
-- VIRABLE
end;
if nb_errors = 0 then
if te.is_character then
if when_list /= Void then
when_list := when_list.to_runnable_character(Current);
if when_list = Void then
error(start_position,em1);
end;
end;
elseif te.is_integer then
if when_list /= Void then
when_list := when_list.to_runnable_integer(Current);
if when_list = Void then
error(start_position,em1);
end;
end;
else
eh.append("Expression must be INTEGER or CHARACTER.");
eh.add_type(te," is not allowed.");
eh.add_position(start_position);
eh.print_as_error;
end;
end;
if else_compound /= Void then
else_compound := else_compound.to_runnable(ct);
end;
Result := Current
else
Result := twin;
!!wl.from_when_list(when_list);
Result.set_when_list(wl);
Result.clear_current_type;
Result := Result.to_runnable(ct);
end;
end;
feature
pretty_print is
do
fmt.keyword(fz_inspect);
fmt.level_incr;
if not fmt.zen_mode then
fmt.indent;
end;
fmt.set_semi_colon_flag(false);
expression.pretty_print;
fmt.level_decr;
fmt.indent;
if when_list /= Void then
when_list.pretty_print;
end;
if else_compound = Void then
if not else_position.is_unknown then
fmt.indent;
fmt.keyword(fz_else);
end;
else
fmt.indent;
fmt.keyword(fz_else);
fmt.level_incr;
else_compound.pretty_print;
fmt.level_decr;
end;
fmt.indent;
fmt.keyword("end;");
if fmt.print_end_inspect then
fmt.put_end(fz_inspect);
end;
end;
feature {E_INSPECT}
set_when_list(wl: like when_list) is
do
when_list := wl;
ensure
when_list = wl;
end;
feature {NONE}
em1: STRING is "Bad inspect.";
feature {E_INSPECT}
clear_current_type is
do
current_type := Void;
ensure
current_type = Void
end;
invariant
expression /= Void;
end -- E_INSPECT